//给定一个经过编码的字符串，返回它解码后的字符串。
//
// 编码规则为: k[encoded_string]，表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。
//
// 你可以认为输入字符串总是有效的；输入字符串中没有额外的空格，且输入的方括号总是符合格式要求的。
//
// 此外，你可以认为原始数据不包含数字，所有的数字只表示重复的次数 k ，例如不会出现像 3a 或 2[4] 的输入。
//
//
//
// 示例 1：
//
//
//输入：s = "3[a]2[bc]"
//输出："aaabcbc"
//
//
// 示例 2：
//
//
//输入：s = "3[a2[c]]"
//输出："accaccacc"
//
//
// 示例 3：
//
//
//输入：s = "2[abc]3[cd]ef"
//输出："abcabccdcdcdef"
//
//
// 示例 4：
//
//
//输入：s = "abc3[cd]xyz"
//输出："abccdcdcdxyz"
//
//
//
//
// 提示：
//
//
// 1 <= s.length <= 30
// s 由小写英文字母、数字和方括号 '[]' 组成
// s 保证是一个 有效 的输入。
// s 中所有整数的取值范围为 [1, 300]
//
// Related Topics 栈 递归 字符串 👍 1191 👎 0

package leetcode.editor.cn;

@SuppressWarnings("all")
//Java：字符串解码
public class 字符串解码 {
    public static void main(String[] args) {
        Solution solution = new 字符串解码().new Solution();
        // TO TEST
        System.out.println(solution.decodeString("3[a2[c]]"));
    }

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public String decodeString(String s) {
            return dfs(s, 0, s.length() - 1, 1);
        }

        public String dfs(String s, int l, int r, int k) {
            StringBuilder path = new StringBuilder();
            int m = 0;
            int rr = -1;
            for (int i = l; i <= r; i++) {
                char ch = s.charAt(i);
                if (ch >= '0' && ch <= '9') {
                    m = m * 10 + ch - '0';
                } else if (ch >= 'a' && ch <= 'z') {
                    path.append(ch);
                } else {
                    rr = i + 1;
                    int count = 0;
                    while (rr < s.length() && !(s.charAt(rr) == ']' && count == 0)) {
                        if (s.charAt(rr) == '[')
                            count++;
                        if (count > 0 && s.charAt(rr) == ']')
                            count--;
                        rr++;
                    }
                    String dfs = dfs(s, i + 1, rr - 1, m);
                    m = 0;
                    path.append(dfs);
                    if (rr != -1) {
                        i = rr;
                        rr = -1;
                    }
                }
            }

            String ss = path.toString();
            for (int i = 0; i < k - 1; i++) {
                path.append(ss);
            }
            return path.toString();
        }
    }
//leetcode submit region end(Prohibit modification and deletion)


}
